* {
  /* 初始化 取消页面元素内外边距 */
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  /* 100%的窗口高度 */
  height: 100vh;
  /* 弹性布局 水平 垂直居中 */
  display: flex;
  justify-content: center;
  align-items: center;
  /* 渐变背景 */
  background: linear-gradient(200deg, #eef1f5, #e6e9f0);
}

.nav {
  display: flex;
  background-color: #b7a1eb;
  height: 100px;
  /* 圆角 */
  border-radius: 20px;
  /* 溢出隐藏 */
  overflow: hidden;
  /* 阴影 */
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.15);
}

.nav .menu {
  list-style: none;
  display: flex;
  justify-content: center;
}

.nav .menu .item {
  position: relative;
  /* 鼠标放上变小手 */
  cursor: pointer;
  padding: 0 10px;
  width: 150px;
  height: 100%;
  /* 加个动画过渡 */
  transition: all 0.4s ease;
}

.nav .menu .item:hover {
  background-color: #a38bdb;
}

.nav .menu .item .link {
  /* block此元素可以将显示为块级元素 */
  display: block;
  /* 生成相对定位的元素，相对于其正常位置进行定位 */
  position: relative;
  width: 100%;
  height: 100px;
  color: #fff;
  /* 去除a标签下划线 */
  text-decoration: none;
  /* 溢出隐藏 */
  overflow: hidden;
  /* 加个动画过渡 */
  transition: all 0.4s ease;
}

.nav .menu .item .link .fa {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  text-align: center;
  /* 加个动画过渡 */
  transition: all 0.4s ease;
}

.nav .menu .item .link span {
  position: absolute;
  width: 100%;
  bottom: -50%;
  left: 0;
  text-align: center;
  opacity: 0;
  /* 加个动画过渡 */
  transition: all 0.4s ease;
}

.nav .menu .item:hover .link span {
  /* 鼠标上移 */
  opacity: 1;
  bottom: 18px;
}

.nav .menu .item:hover .link .fa {
  /* 鼠标移入图标上移 */
  transform: translateY(-95%);
}
